using Microsoft. AspNetCore. Builder; 

using Microsoft. AspNetCore.Hosting; 

using Microsoft.AspNetCore. Identity; 

using Microsoft.AspNetCore.Mvc; 

using Microsoft.EntityFrameworkCore; 

using Microsoft.Extensions.Configuration; 

using Microsoft. Extensions.Dependencylnjection; 
using Microsoft.Extensions.Hosting; 

using MyCompany.Domain; 

using MyCompany.Domain.Repositories.Abstract; 
using MyCompany.Domain.Repositories.Entity Framework; 
using MyCompany.Service; 


namespace MyCompany 
( 
public class Startup 
{ 
public IConfiguration Configuration { get; } 
public Startup(IConfiguration configuration) => Configuration = configuration; 


public void ConfigureServices(IServiceCollection services) 
{ 
/Niäsep-aäl étidea ec appsetting.json 
Configuration.Bind("Project", new Config()); 


/Niäsep-aäl ióseiúé Ööleöeliae ¡desgtecáley á dar ánodá Nadaenia 
services.AddTransient<ITextFieldsRepository, EFTextFieldsRepository>(); 
services.AddTransient<IServiceltemsRepository, EFServiceltemsRepository>(); 
services.AddTransient<DataManager>(); 


Mäsep-aäl eriváéeño AA 
services. AddDbContext<AppDbContext>(x => 
x.UseSalServer(Config.ConnectionString)); 


NN LENZ 


services.Addidentity<IdentityUser, IdentityRole>(opts => 
{ 
opts.User.RequireUniqueEmail = true; 
opts.Password.RequiredLength = 6; 
opts.Password.RequireNonAlphanumeric = false; 
opts.Password.RequireLowercase = false; 
opts.Password.RequireUppercase = false; 
opts.Password.RequireDigit = false; 
}).AddEntityFrameworkStores<AppDbContext>().AddDefaultTokenProviders(); 


Xr AX OV 


services.ConfigureApplicationCookie(options => 


{ 


options.Cookie.Name = "myCompanyAuth"; 
options.Cookie.HttpOnly = true; 

options.LoginPath = "/account/login"; 
options.AccessDeniedPath = "/account/accessdenied"; 
options.SlidingExpiration = true; 


HF 


Nanodasaaal Mécoeéó añdidecades AEY Admin area 
services.AddAuthorization(x => 

{ 

x.AddPolicy("AdminArea", policy => { policy.RequireRole("admin"); }); 
p); 


//aiaaaéyai nádaeñú aéy Elioöiesadıa e jhaandaadalee (MVC) 
services.AddControllersWithViews(x => 

{ 

x.Conventions.Add(new AdminAreaAuthorization("Admin", "AdminArea")); 

}) 

Naunoaasyal Aiaianoeiinou A asp.net core 3.0 

.SetCompatibility Version(Compatibility Version. Version_3_0).AddSessionStateTem 

pDataProvider(); 


} 


public void Configure(lApplicationBuilder app, IWebHostEnvironment env) 


( 


° = X Z À 


//& Oidanha Dacdaáloée íal áaceíí âèäåòü Cadeá eilälli iaeaée 
if (env.IsDevelopment()) 
app.UseDeveloperExceptionPage(); 


/Niäsep-aäl ääåðöæêó ñoaoe- (00 6aéëia A idedlzeälee (css, js ë 0.á.) 
app.UseStaticFiles(); 


ZINN. XXX 


app.UseRouting(); 


/Niäsep-aäl addaidedeeadep e aadidecadep 
app.UseCookiePolicy(); 
app.UseAuthentication(); 
app.UseAuthorization(); 


daaeho0e000äl ideeita iai iad@d600 (Aläfleioü) 
app.UseEndpoints(endpoints => 
{ 
endpoints.MapControllerRoute("admin", 
"{area:exists}/{controller=Home}/{action=Index}/{id?}"); 
endpoints.MapControllerRoute("default", "{controller=Home}/{action=Index}/{id?}"); 


